import router from '@/router'
import store from '@/store'
// 导入进度条
import Nprogress from 'nprogress'
import 'nprogress/nprogress.css'

const pageArr = ['/404', '/login'] // 不需要登录页面
// 导航前置守卫
router.beforeEach(async(to, from, next) => {
  Nprogress.start()
  if (store.getters.token) {
    if (to.path.toLowerCase() === '/login') {
      next('/')
    } else {
      // 验证token获取用户信息
      // 没有用户信息才获取
      if (!store.state.user.userInfo.userId) {
        await store.dispatch('user/getUserInfo')
        // 添加的动态路由不能立马使用，需在经过导航守卫
        next(to.fullPath)
      } else {
        next()
      }
    }
  } else {
    if (pageArr.includes(to.path.toLowerCase())) {
      next()
    } else {
      // ie 不知支持中文字符
      next(`/login?redirect=${encodeURIComponent(to.fullPath)}`)
    }
  }
  Nprogress.done()
})
// 导航后置守卫
router.afterEach((to, from) => {
  Nprogress.done()
})
